<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=2">
<meta name="theme-color" content="#222">
<meta name="generator" content="Hexo 5.4.0">
  <link rel="apple-touch-icon" sizes="180x180" href="/images/apple-touch-icon-next.png">
  <link rel="icon" type="image/png" sizes="32x32" href="/images/astronaut32.png">
  <link rel="icon" type="image/png" sizes="16x16" href="/images/astronaut16.png">
  <link rel="mask-icon" href="/images/logo.svg" color="#222">

<link rel="stylesheet" href="/css/main.css">

<link rel="stylesheet" href="fonts.googleapis.com/css?family=EB Garamond:300,300italic,400,400italic,700,700italic|Cinzel Decorative:300,300italic,400,400italic,700,700italic|Noto Serif SC:300,300italic,400,400italic,700,700italic|Source Code Pro:300,300italic,400,400italic,700,700italic&display=swap&subset=latin,latin-ext">
<link rel="stylesheet" href="/lib/font-awesome/css/all.min.css">
  <link rel="stylesheet" href="//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.css">
  <link rel="stylesheet" href="/lib/pace/pace-theme-pace-theme-minimal.min.css">
  <script src="/lib/pace/pace.min.js"></script>

<script id="hexo-configurations">
    var NexT = window.NexT || {};
    var CONFIG = {"hostname":"fat_fat_where_are_you.gitee.io","root":"/","scheme":"Gemini","version":"7.8.0","exturl":false,"sidebar":{"position":"left","display":"post","padding":18,"offset":12,"onmobile":false},"copycode":{"enable":true,"show_result":true,"style":"mac"},"back2top":{"enable":false,"sidebar":false,"scrollpercent":false},"bookmark":{"enable":false,"color":"#222","save":"auto"},"fancybox":true,"mediumzoom":false,"lazyload":true,"pangu":false,"comments":{"style":"tabs","active":null,"storage":true,"lazyload":false,"nav":null},"algolia":{"hits":{"per_page":10},"labels":{"input_placeholder":"Search for Posts","hits_empty":"We didn't find any results for the search: ${query}","hits_stats":"${hits} results found in ${time} ms"}},"localsearch":{"enable":true,"trigger":"auto","top_n_per_article":1,"unescape":false,"preload":false},"motion":{"enable":true,"async":false,"transition":{"post_block":"fadeIn","post_header":"slideDownIn","post_body":"slideDownIn","coll_header":"slideLeftIn","sidebar":"slideUpIn"}},"path":"search.xml"};
  </script>

<link href="https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@500&display=swap" rel="stylesheet">
  <meta name="description" content="在写PRD、竞品分析文档中，我们常常会看到产品结构图、产品功能结构图或者产品信息结构图的身影，但需要讲清楚他们的定义和作用也真没看上去那么简单，这里作者尝试分享一下自己的观点。">
<meta property="og:type" content="article">
<meta property="og:title" content="产品结构图">
<meta property="og:url" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8.html">
<meta property="og:site_name" content="肥肉啊肥肉你在哪">
<meta property="og:description" content="在写PRD、竞品分析文档中，我们常常会看到产品结构图、产品功能结构图或者产品信息结构图的身影，但需要讲清楚他们的定义和作用也真没看上去那么简单，这里作者尝试分享一下自己的观点。">
<meta property="og:locale" content="zh_CN">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/1-62.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/2-49.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/3-28.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/4-24.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/5-27.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/2-84.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/3-54.png">
<meta property="og:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/4-50.png">
<meta property="article:published_time" content="2020-09-16T01:33:23.000Z">
<meta property="article:modified_time" content="2020-09-16T01:33:23.000Z">
<meta property="article:author" content="肥肉啊肥肉你在哪">
<meta name="twitter:card" content="summary">
<meta name="twitter:image" content="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8/1-62.png">

<link rel="canonical" href="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8.html">


<script id="page-configurations">
  // https://hexo.io/docs/variables.html
  CONFIG.page = {
    sidebar: "",
    isHome : false,
    isPost : true,
    lang   : 'zh-CN'
  };
</script>
<link rel="stylesheet" type="text/css" href="/css/injector/main.css"><link rel="preload" as="style" href="/css/injector/light.css"><link rel="preload" as="style" href="/css/injector/dark.css">
  <title>产品结构图 | 肥肉啊肥肉你在哪</title>
  






  <noscript>
  <style>
  .use-motion .brand,
  .use-motion .menu-item,
  .sidebar-inner,
  .use-motion .post-block,
  .use-motion .pagination,
  .use-motion .comments,
  .use-motion .post-header,
  .use-motion .post-body,
  .use-motion .collection-header { opacity: initial; }

  .use-motion .site-title,
  .use-motion .site-subtitle {
    opacity: initial;
    top: initial;
  }

  .use-motion .logo-line-before i { left: initial; }
  .use-motion .logo-line-after i { right: initial; }
  </style>
</noscript>

  <script src="https://cdn.jsdelivr.net/npm/jquery/dist/jquery.min.js"></script>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/font-awesome/css/font-awesome.min.css">

</head>

<body itemscope itemtype="http://schema.org/WebPage">
  <div class="container use-motion">
    <div class="headband"></div>

    <header class="header" itemscope itemtype="http://schema.org/WPHeader">
      <div class="header-inner"><div class="site-brand-container">
  <div class="site-nav-toggle">
    <div class="toggle" aria-label="切换导航栏">
      <span class="toggle-line toggle-line-first"></span>
      <span class="toggle-line toggle-line-middle"></span>
      <span class="toggle-line toggle-line-last"></span>
    </div>
  </div>

  <div class="site-meta">

    <a href="/" class="brand" rel="start">
      <span class="logo-line-before"><i></i></span>
      <h1 class="site-title">肥肉啊肥肉你在哪</h1>
      <span class="logo-line-after"><i></i></span>
    </a>
  </div>

  <div class="site-nav-right">
    <div class="toggle popup-trigger">
        <i class="fa fa-search fa-fw fa-lg"></i>
    </div>
  </div>
</div>




<nav class="site-nav">
  <ul id="menu" class="main-menu menu">
        <li class="menu-item menu-item-home">

    <a href="/" rel="section"><i class="fa fa-home fa-fw"></i>首页</a>

  </li>
        <li class="menu-item menu-item-tags">

    <a href="/tags/" rel="section"><i class="fa fa-tags fa-fw"></i>标签</a>

  </li>
        <li class="menu-item menu-item-categories">

    <a href="/categories/" rel="section"><i class="fa fa-th fa-fw"></i>分类</a>

  </li>
        <li class="menu-item menu-item-archives">

    <a href="/archives/" rel="section"><i class="fa fa-archive fa-fw"></i>归档</a>

  </li>
        <li class="menu-item menu-item-movies">

    <a href="/movies/" rel="section"><i class="fa fa-film fa-fw"></i>观影</a>

  </li>
        <li class="menu-item menu-item-books">

    <a href="/books/" rel="section"><i class="fa fa-book fa-fw"></i>阅读</a>

  </li>
      <li class="menu-item menu-item-search">
        <a role="button" class="popup-trigger"><i class="fa fa-search fa-fw"></i>搜索
        </a>
      </li>
  </ul>
</nav>



  <div class="search-pop-overlay">
    <div class="popup search-popup">
        <div class="search-header">
  <span class="search-icon">
    <i class="fa fa-search"></i>
  </span>
  <div class="search-input-container">
    <input autocomplete="off" autocapitalize="off" placeholder="搜索..." spellcheck="false" type="search" class="search-input">
  </div>
  <span class="popup-btn-close">
    <i class="fa fa-times-circle"></i>
  </span>
</div>
<div id="search-result">
  <div id="no-result">
    <i class="fa fa-spinner fa-pulse fa-5x fa-fw"></i>
  </div>
</div>

    </div>
  </div>

</div>
    </header>

    
  <div class="reading-progress-bar"></div>


    <main class="main">
      <div class="main-inner">
        <div class="content-wrap">
          

          <div class="content post posts-expand">
            

    
  
  
  <article itemscope itemtype="http://schema.org/Article" class="post-block" lang="zh-CN">
    <link itemprop="mainEntityOfPage" href="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8.html">

    <span hidden itemprop="author" itemscope itemtype="http://schema.org/Person">
      <meta itemprop="image" content="/images/touxiang.gif">
      <meta itemprop="name" content="肥肉啊肥肉你在哪">
      <meta itemprop="description" content>
    </span>

    <span hidden itemprop="publisher" itemscope itemtype="http://schema.org/Organization">
      <meta itemprop="name" content="肥肉啊肥肉你在哪">
    </span>
      <header class="post-header">
        <h1 class="post-title" itemprop="name headline">
          产品结构图
        </h1>

        <div class="post-meta">
            <span class="post-meta-item">
              <span class="post-meta-item-icon">
                <i class="far fa-calendar"></i>
              </span>
              <span class="post-meta-item-text">发表于</span>

              <time title="创建时间：2020-09-16 09:33:23" itemprop="dateCreated datePublished" datetime="2020-09-16T09:33:23+08:00">2020-09-16</time>
            </span>
            <span class="post-meta-item">
              <span class="post-meta-item-icon">
                <i class="far fa-folder"></i>
              </span>
              <span class="post-meta-item-text">分类于</span>
                <span itemprop="about" itemscope itemtype="http://schema.org/Thing">
                  <a href="/categories/%E4%BA%A7%E5%93%81/" itemprop="url" rel="index"><span itemprop="name">产品</span></a>
                </span>
            </span>

          
          
          <br>
            <span id="/archives/8a599ed8.html" class="post-meta-item leancloud_visitors" data-flag-title="产品结构图" title="阅读次数">
              <span class="post-meta-item-icon">
                <i class="fa fa-eye"></i>
              </span>
              <span class="post-meta-item-text">阅读次数：</span>
              <span class="leancloud-visitors-count"></span>
            </span>
  
  <span class="post-meta-item">
    
      <span class="post-meta-item-icon">
        <i class="far fa-comment"></i>
      </span>
      <span class="post-meta-item-text">Valine：</span>
    
    <a title="valine" href="/archives/8a599ed8.html#valine-comments" itemprop="discussionUrl">
      <span class="post-comments-count valine-comment-count" data-xid="/archives/8a599ed8.html" itemprop="commentCount"></span>
    </a>
  </span>
  
  <br>
            <span class="post-meta-item" title="本文字数">
              <span class="post-meta-item-icon">
                <i class="far fa-file-word"></i>
              </span>
                <span class="post-meta-item-text">本文字数：</span>
              <span>3.9k</span>
            </span>
            <span class="post-meta-item" title="阅读时长">
              <span class="post-meta-item-icon">
                <i class="far fa-clock"></i>
              </span>
                <span class="post-meta-item-text">阅读时长 &asymp;</span>
              <span>4 分钟</span>
            </span>

        </div>
      </header>

    
    
    
    <div class="post-body" itemprop="articleBody">

      
        <blockquote>
<p>在写 PRD、竞品分析文档中，我们常常会看到产品结构图、产品功能结构图或者产品信息结构图的身影，但需要讲清楚他们的定义和作用也真没看上去那么简单，这里作者尝试分享一下自己的观点。</p>
</blockquote>
<span id="more"></span>

<p>特别声明：由于篇幅和其他因素限制，本系列中所有的实例图在完整性上有省略和简化，仅作为举例讲解用，请读者不要纠结图表是否描述完整、是否有缺失模块，主要是给读者来对比 3 类图表的联系与区别。</p>
<h2 id="功能结构图"><a href="# 功能结构图" class="headerlink" title="功能结构图"></a>功能结构图 </h2><h3 id="1 定义"><a href="#1 定义" class="headerlink" title="1 定义"></a><strong>1 定义</strong></h3><p> 功能结构图就是按照功能的从属关系画成的图表，在该图表中的每一个框都称为一个功能模块。功能模块可以根据具体情况分得大一点或小一点，分解得最小功能模块可以是一个程序中的每个处理过程，而较大的功能模块则可能是完成某一个任务的一组程序。（百度定义）用通俗的话来说，<strong>功能结构图就是以功能模块为类别，介绍模块下其各功能组成的图表。</strong></p>
<h3 id="2 作用"><a href="#2 作用" class="headerlink" title="2 作用"></a><strong>2 作用</strong></h3><ol>
<li> 产品概念设计的运用工具之一，能够对不完全确定的设计问题或相当模糊的设计要求，以一种较为简洁和明确的方法表示。在绘制的过程中，能够帮助 PM 思考并清晰产品的功能模块及其功能组成；</li>
<li> 梳理需求，以鸟瞰的方式对整个产品页面中的功能结构形成一个直观的认识，防止在产品需求转化为功能需求的过程中出现功能模块和功能点缺失的现象。</li>
</ol>
<h3 id="3 注意事项"><a href="#3 注意事项" class="headerlink" title="3 注意事项"></a><strong>3 注意事项 </strong></h3><p> 在区分功能结构、信息结构图、结构图前，有一个重要的前提需要大家达成共识：软件产品本身就是传递信息和提供功能的载体，完全绝对的信息类或功能类产品是不可能存的在，信息往往伴随着功能，我们很难划一条界限将两者彻底分开。从某种意义上，信息传递甚至就是软件产品最主要的核心功能。鉴于此，<strong>通常我们默认地把信息展示功能独立了出来，作为信息架构的一部分去思考，在产品功能结构时不考虑信息展示功能。</strong></p>
<p>这里举一个信息与功能纠缠的例子更好理解，如微信的个人信息模块（如下图），“名字”字段在这里既是信息又提供着修改设置的功能。</p>
<img data-src="/archives/8a599ed8/1-62.png" class>

<p>所以我们不难理解许多功能结构图中出现了信息结构的要素，但由于功能结构图的使用目的（即上文中的作用）要求我们专注于产品功能这个维度，在功能结构图中我们最好尽量减少信息结构要素出现的可能性。</p>
<p>就用上面功能与信息纠缠的例子来说，在其功能结构图中许多朋友会直接用“名字”来表示其功能点，画图人可能本人清楚，但看图人就会产生疑惑：这个“名字”到底是指提供可查看名字的功能还是可查看并修改名字的功能。</p>
<p>在这里介绍一个小诀窍，形容一个功能点时建议多采用“<strong>动词 + 名词</strong>”的语言描述形式，这种方式不仅信息传达更加准确而且可以避免读者不必要的困惑。如上面的例子中我们就可以把“名字”改为“设置名字”或“查看并设置名字”来描述功能点。</p>
<h3 id="4 如何绘制功能结构图"><a href="#4 如何绘制功能结构图" class="headerlink" title="4 如何绘制功能结构图"></a><strong>4 如何绘制功能结构图 </strong></h3><p> 在实际应用时，产品功能结构图通常在以下 2 种情况下绘制：</p>
<ul>
<li><strong>对未完成的产品在设计阶段绘制，确定产品功能结构；</strong></li>
<li><strong>对已完成的某个版本的产品绘制，用于分析并传递该产品的功能结构；</strong></li>
</ul>
<p><strong>（一）在产品的设计阶段，如何挖掘并确定功能结构图中的主功能模块呢？</strong></p>
<p>首先主功能模块应该是产品在完整业务流程中的各个核心功能模块，我们可通过业务流程中所涉及到的功能需求去提炼出主功能模块，提炼完成后再通过业务流程走查一次，看是否有遗漏的主功能模块。</p>
<p>举个例子，假设我们参与了微信的早期功能设计，其产品初期定位是一款移动社交软件，那么其对应的核心业务可以简化为</p>
<img data-src="/archives/8a599ed8/2-49.png" class>

<p>这样我们就很容易得出产品设计阶段微信的主功能模块，如下：</p>
<img data-src="/archives/8a599ed8/3-28.png" class>

<p>结合下面现有版本的微信功能结构图对比一下，经过上百次迭代，其主功能结构几乎没有发生变化，我们不得不佩服其功能结构的拓展性；</p>
<img data-src="/archives/8a599ed8/4-24.png" class>



<p>当通过业务流程将主功能模块确定下来后，再根据业务需求对其进行功能的详细设计即可，在此就不再展开了。</p>
<p><strong>2. 对于已确定产品来说如何绘制功能结构图呢？</strong></p>
<p>对一款已确定产品绘制功能结构图，最快捷的方法便是参考产品的 Tab 功能模块找出产品主功能模块，然后按照层级归属关系详叙该功能模块提供的下一级功能模块或功能，如有必要，其颗粒度可一直细化到功能操作的描述程度。</p>
<p><strong>那上图“微信功能结构图（V6.5.21）”的主功能模块为什么不是“微信”、“通讯录”、“发现”、“我”这四大标签功能模块？</strong></p>
<p>在这里作者希望传达一个概念，结构图中的主功能模块不一定就是 Tab 中的标签功能模块，许多时候产品受限于移动端的空间限制，不得不把功能分为 3 到 4 个 Tab 中，这是一种务实的妥协。当然正常情况下以 Tab 标签名作为主功能模块的做法没有错，只是当产品功能复杂时，产品功能结构图采用这种划分有点粗糙。而绘制已确定产品的功能结构图能够帮助我们去挖掘这个产品的核心功能模块，梳理产品的功能架构。我们建议作图人可以尝试脱离 Tab 标签用自己的语言去挖掘并描述主功能模块。</p>
<p><strong>这样说来我们就可以随意将标签功能模块中的次级功能模块划分出来作为主功能模块吗？</strong></p>
<p>其实也不是，一款不管多复杂的应用其主功能模块的划分数量都不能太多（5-9 个为佳），一般情况下当对产品功能结构进行分析后，我们仍然会采用 Tab 功能模块作为主功能模块然后对其下属的功能模块进行整理。只有当我们认为某个次级功能模块在业务上太过重要且产品价值较高时，我们才可以将其划分出来作为一个单独的主功能模块。</p>
<p>这里介绍一个小秘诀，当一个次级功能模块反复出现在不同的 Tab 功能模块中的时候，我们就可以考虑将其拆分出来作为主功能模块，因为这个时候意味着这个次级功能模块在产品的业务流程中来说十分重要，而且这也可以让我们的产品功能结构图更加简洁清楚。如上面“微信功能结构图（V6.5.21）”中的搜索模块就同时出现在了 Tab 中的微信功能模块和通讯录功能模块。</p>
<p><strong>最后如何确定功能结构图中的颗粒度呢？</strong></p>
<p>功能结构图中的颗粒程度需要根据具体应用场景来定，由画图人根据需要自行把控即可 <strong>。</strong> 比如说在产品设计的过程中，功能结构的建立是设计者的设计思维由发散趋向于收敛的过程，刚开始的颗粒度一般比较大，可能仅涉及到某个功能模块，随着设计的不断推进，功能结构图的颗粒度会不断细化，最终可以拆分至某个具体的功能操作。这里作者将“微信模块 - 个人对话”功能模块作了细化，仅供参考：</p>
<img data-src="/archives/8a599ed8/5-27.png" class>



<h2 id="信息结构图"><a href="# 信息结构图" class="headerlink" title="信息结构图"></a>信息结构图</h2><ul>
<li>定义：指脱离产品的实际页面，将产品的数据抽象出来，组合分类的图表。</li>
<li>作用：</li>
</ul>
<ol>
<li> 帮助 PM 梳理复杂内容的信息组成，避免信息内容在展示过程中出现遗漏、混乱、重复；</li>
<li> 作为开发工程师建立数据库的参考依据；</li>
</ol>
<p>信息结构图的绘制通常晚于功能结构图，往往是在产品设计阶段的概念化过程中，在产品功能框架已确定、功能结构已完善好的情况下才对产品信息结构进行分析设计。</p>
<p>在这里，我们需要强调的是脱离实际页面这个概念，在一些产品相关文章中，我们会看到作者将信息结构图完全按照页面的逻辑顺序来进行分类组合，严格意义上来说，这种图表不是一份合格的信息结构图。</p>
<p>我们用微信的个人信息模块举例，如下图所示：</p>


<p>其结构信息图在这部分的绘制就需要脱离产品的实际页面，如下：</p>
<img data-src="/archives/8a599ed8/2-84.png" class>

<p>最后需要强调的是：信息结构图主要适用于产品信息构成比较复杂需要考虑优化的情况，如内容型产品（博客、web 门户网站等），产品的信息结构对于用户体验就十分重要，需要用信息结构图作为工具进行分析思考。</p>
<p>这里作者简单绘制了一下微信的信息结构图作为参考</p>
<img data-src="/archives/8a599ed8/3-54.png" class>

<h2 id="结构图"><a href="# 结构图" class="headerlink" title="结构图"></a>结构图 </h2><p> 相较于功能结构图和信息结构图，产品结构图的定义就很混乱和模糊了，为什么会出现这种情况呢？</p>
<p>一方面产品结构图从文字理解上来说就容易让人困惑：产品信息结构图、产品功能结构图不都可以简称为产品结构图嘛。</p>
<p>另一方面现有网上流传的竞品分析文档、产品体验文档、PRD 文档有不少是由产品新人模仿前辈流传出来的文档模板来写的。但让人尴尬的是，有部分同学没有进行细致深入地了解。经常在一篇文章中，前面说是产品的功能结构图，结果图中是产品功能有，产品信息要素也有，没有理解功能结构图的定义。而后来的初学者又从这些文章中去了解学习产品功能结构图、产品信息结构图，导致恶性循环；</p>
<p>最重要的原因是：对于产品结构图，产品从业人员这个群体自身都还没有达成共识啊。作者在网上搜了搜相关文章，对于产品结构图大家的主要理解有 3 种：</p>
<ul>
<li><strong>大部分产品人认为：</strong>产品结构图即产品功能结构图的简称，可能在产品没有强调信息结构的概念时，有部分 PM 开始简称产品功能结构图为产品结构图，之后便默认了这种称呼，当出现产品信息结构图后，概念就产生了混淆；</li>
<li><strong>一部分产品人认为：</strong>产品结构图是综合展示产品信息和功能逻辑的图表；</li>
<li><strong>少部分产品人认为：</strong>产品结构图就是产品信息架构图。</li>
</ul>
<p>在这里，作者更认同第 2 种观念：</p>
<p><strong>产品结构图是综合展示产品信息和功能逻辑的图表 ****，简单说产品结构图就是产品原型的简化表达。</strong>它能够在前期的需求评审中或其他类似场景中作为产品原型的替代，因为产品结构图相较于产品原型，其实现成本低，能够快速对产品功能结构进行增、删、改操作，减少 PM 在这个过程中的实现成本。</p>
<p>产品结构图就是通过信息架构设计，将功能和信息以一种合理自然的逻辑，把功能结构图和信息结构图中的内容放入产品中的每一个页面的结果。而现在许多 PRD、竞品分析中提到的信息结构图、功能结构图其实大多数都是同时含有功能和信息元素的简化版产品结构图。如下图所示：</p>
<img data-src="/archives/8a599ed8/4-50.png" class>

<h2 id="总结"><a href="# 总结" class="headerlink" title="总结"></a>总结 </h2><p> 在一款产品的设计过程中，功能结构图是必须的，信息结构图视产品和 PM 自身而定，通常我们初步确定了产品功能结构图（产品功能框架）之后才开始绘制产品信息结构图。</p>
<p>在产品设计流程中，产品功能结构图是产品概念化阶段的初期输出，产品结构图是产品概念化的尾期阶段输出物，当产品结构图完成后，我们对产品的基本模样在心理就有了一个轮廓。同时以产品结构图作为绘制原型的依据，可以避免我们在产品设计中边画边改，跳进死掐细节，不见森林的陷阱。</p>
<p>到这里，你是否还对功能结构图、信息结构图、结构图傻傻分不清呢？</p>
<blockquote>
<p>本文转载自<a target="_blank" rel="external nofollow noopener noreferrer" href="http://www.woshipm.com/pmd/844937.html">http://www.woshipm.com/pmd/844937.html</a> 侵删</p>
</blockquote>

    </div>

    
    
    
      

        <div class="reward-container">
  <div>感谢各位打赏的小伙伴</div>
  <button onclick="var qr = document.getElementById('qr'); qr.style.display = (qr.style.display === 'none') ? 'block' : 'none';">
    打赏
  </button>
  <div id="qr" style="display: none;">
      
      <div style="display: inline-block;">
        <img src="/images/wechatpay.png" alt="肥肉啊肥肉你在哪 微信支付">
        <p>微信支付</p>
      </div>
      
      <div style="display: inline-block;">
        <img src="/images/alipay.png" alt="肥肉啊肥肉你在哪 支付宝">
        <p>支付宝</p>
      </div>

  </div>
</div>

        

<div>
<ul class="post-copyright">
  <li class="post-copyright-author">
    <strong>本文作者： </strong>肥肉啊肥肉你在哪
  </li>
  <li class="post-copyright-link">
    <strong>本文链接：</strong>
    <a href="http://fat_fat_where_are_you.gitee.io/archives/8a599ed8.html" title="产品结构图">http://fat_fat_where_are_you.gitee.io/archives/8a599ed8.html</a>
  </li>
  <li class="post-copyright-license">
    <strong>版权声明： </strong>本博客所有文章除特别声明外，均采用 <a href="https://creativecommons.org/licenses/by-nc-sa/4.0/" rel="external nofollow noopener noreferrer" target="_blank"><i class="fab fa-fw fa-creative-commons"></i>BY-NC-SA</a> 许可协议。转载请注明出处！
  </li>
</ul>
</div>


      <footer class="post-footer">

        
  <div class="post-widgets">
    <div class="wp_rating">
      <div id="wpac-rating"></div>
    </div>
  </div>


        
    <div class="post-nav">
      <div class="post-nav-item">
    <a href="/archives/394b329c.html" rel="prev" title="Kano 模型">
      <i class="fa fa-chevron-left"></i> Kano 模型
    </a></div>
      <div class="post-nav-item">
    <a href="/archives/fe828b57.html" rel="next" title="哔哩哔哩竞品分析">
      哔哩哔哩竞品分析 <i class="fa fa-chevron-right"></i>
    </a></div>
    </div>
      </footer>
    
  </article>
  
  
  



          </div>
          
    <div class="comments" id="valine-comments"></div>

<script>
  window.addEventListener('tabs:register', () => {
    let { activeClass } = CONFIG.comments;
    if (CONFIG.comments.storage) {
      activeClass = localStorage.getItem('comments_active') || activeClass;
    }
    if (activeClass) {
      let activeTab = document.querySelector(`a[href="#comment-${activeClass}"]`);
      if (activeTab) {
        activeTab.click();
      }
    }
  });
  if (CONFIG.comments.storage) {
    window.addEventListener('tabs:click', event => {
      if (!event.target.matches('.tabs-comment .tab-content .tab-pane')) return;
      let commentClass = event.target.classList[1];
      localStorage.setItem('comments_active', commentClass);
    });
  }
</script>

        </div>
          
  
  <div class="toggle sidebar-toggle">
    <span class="toggle-line toggle-line-first"></span>
    <span class="toggle-line toggle-line-middle"></span>
    <span class="toggle-line toggle-line-last"></span>
  </div>

  <aside class="sidebar">
    <div class="sidebar-inner">

      <ul class="sidebar-nav motion-element">
        <li class="sidebar-nav-toc">
          文章目录
        </li>
        <li class="sidebar-nav-overview">
          站点概览
        </li>
      </ul>

      <!--noindex-->
      <div class="post-toc-wrap sidebar-panel">
          <div class="post-toc motion-element"><ol class="nav"><li class="nav-item nav-level-2"><a class="nav-link" href="#%E5%8A%9F%E8%83%BD%E7%BB%93%E6%9E%84%E5%9B%BE"><span class="nav-text">功能结构图 </span></a><ol class="nav-child"><li class="nav-item nav-level-3"><a class="nav-link" href="#1%20%E5%AE%9A%E4%B9%89"><span class="nav-text">1 定义</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#2%20%E4%BD%9C%E7%94%A8"><span class="nav-text">2 作用</span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#3%20%E6%B3%A8%E6%84%8F%E4%BA%8B%E9%A1%B9"><span class="nav-text">3 注意事项 </span></a></li><li class="nav-item nav-level-3"><a class="nav-link" href="#4%20%E5%A6%82%E4%BD%95%E7%BB%98%E5%88%B6%E5%8A%9F%E8%83%BD%E7%BB%93%E6%9E%84%E5%9B%BE"><span class="nav-text">4 如何绘制功能结构图 </span></a></li></ol></li><li class="nav-item nav-level-2"><a class="nav-link" href="#%E4%BF%A1%E6%81%AF%E7%BB%93%E6%9E%84%E5%9B%BE"><span class="nav-text">信息结构图</span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#%E7%BB%93%E6%9E%84%E5%9B%BE"><span class="nav-text">结构图 </span></a></li><li class="nav-item nav-level-2"><a class="nav-link" href="#%E6%80%BB%E7%BB%93"><span class="nav-text">总结 </span></a></li></ol></div>
      </div>
      <!--/noindex-->

      <div class="site-overview-wrap sidebar-panel">
        <div class="site-author motion-element" itemprop="author" itemscope itemtype="http://schema.org/Person">
    <img class="site-author-image" itemprop="image" alt="肥肉啊肥肉你在哪" src="/images/touxiang.gif">
  <p class="site-author-name" itemprop="name">肥肉啊肥肉你在哪</p>
  <div class="site-description" itemprop="description"></div>
</div>
<div class="site-state-wrap motion-element">
  <nav class="site-state">
      <div class="site-state-item site-state-posts">
          <a href="/archives/">
        
          <span class="site-state-item-count">38</span>
          <span class="site-state-item-name">日志</span>
        </a>
      </div>
      <div class="site-state-item site-state-categories">
            <a href="/categories/">
          
        <span class="site-state-item-count">4</span>
        <span class="site-state-item-name">分类</span></a>
      </div>
      <div class="site-state-item site-state-tags">
            <a href="/tags/">
          
        <span class="site-state-item-count">16</span>
        <span class="site-state-item-name">标签</span></a>
      </div>
  </nav>
</div>
  <div class="links-of-author motion-element">
      <span class="links-of-author-item">
        <a href="https://github.com/feirouafeirou" title="GitHub → https:&#x2F;&#x2F;github.com&#x2F;feirouafeirou" rel="external nofollow noopener noreferrer" target="_blank"><i class="fab fa-github fa-fw"></i>GitHub</a>
      </span>
      <span class="links-of-author-item">
        <a href="http://wpa.qq.com/msgrd?v=3&uin=1729013657&site=qq&menu=yes" title="QQ → http:&#x2F;&#x2F;wpa.qq.com&#x2F;msgrd?v&#x3D;3&amp;uin&#x3D;1729013657&amp;site&#x3D;qq&amp;menu&#x3D;yes" rel="external nofollow noopener noreferrer" target="_blank"><i class="fab fa-qq fa-fw"></i>QQ</a>
      </span>
  </div>


  <div class="links-of-blogroll motion-element">
    <div class="links-of-blogroll-title"><i class="fa fa-link fa-fw"></i>
      友情链接
    </div>
    <ul class="links-of-blogroll-list">
        <li class="links-of-blogroll-item">
          <a href="http://www.woshipm.com/" title="http:&#x2F;&#x2F;www.woshipm.com" rel="external nofollow noopener noreferrer" target="_blank">人人都是产品经理</a>
        </li>
        <li class="links-of-blogroll-item">
          <a href="http://www.chanpin100.com/" title="http:&#x2F;&#x2F;www.chanpin100.com" rel="external nofollow noopener noreferrer" target="_blank">产品壹佰</a>
        </li>
    </ul>
  </div>

      </div>

    </div>
  </aside>

  <div id="sidebar-dimmer"></div>


      </div>
    </main>

    <footer class="footer">
      <div class="footer-inner">
        

        

<div class="copyright">
  
  &copy; 2020 – 
  <span itemprop="copyrightYear">2022</span>
  <span class="with-love">
    <i class="fa fa-heart"></i>
  </span>
  <span class="author" itemprop="copyrightHolder">肥肉啊肥肉你在哪</span>
    <span class="post-meta-divider">|</span>
    <span class="post-meta-item-icon">
      <i class="fa fa-chart-area"></i>
    </span>
    <span title="站点总字数">237k</span>
    <span class="post-meta-divider">|</span>
    <span class="post-meta-item-icon">
      <i class="fa fa-coffee"></i>
    </span>
    <span title="站点阅读时长">3:35</span>
</div>

<div class="translate-style">
繁/简：<a id="translateLink" href="javascript:translatePage();">繁体
</a>
</div>
<script type="text/javascript" src="/js/tw_cn.js"></script>
<script type="text/javascript">
var defaultEncoding = 2; //网站编写字体是否繁体，1-繁体，2-简体
var translateDelay = 0; //延迟时间,若不在前, 要设定延迟翻译时间, 如100表示100ms,默认为0
var cookieDomain = "https://feirouafeirou.github.io/"; //Cookie地址, 一定要设定, 通常为你的网址
var msgToTraditionalChinese = "繁体"; //此处可以更改为你想要显示的文字
var msgToSimplifiedChinese = "简体"; //同上，但两处均不建议更改
var translateButtonId = "translateLink"; //默认互换id
translateInitilization();
</script>


        
<div class="busuanzi-count">
  <script async src="https://busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script>
    <span class="post-meta-item" id="busuanzi_container_site_uv" style="display: none;">
      <span class="post-meta-item-icon">
        <i class="fa fa-user"></i>
      </span>
      <span class="site-uv" title="总访客量">
        <span id="busuanzi_value_site_uv"></span>
      </span>
    </span>
    <span class="post-meta-divider">|</span>
    <span class="post-meta-item" id="busuanzi_container_site_pv" style="display: none;">
      <span class="post-meta-item-icon">
        <i class="fa fa-eye"></i>
      </span>
      <span class="site-pv" title="总访问量">
        <span id="busuanzi_value_site_pv"></span>
      </span>
    </span>
</div>








      </div>
    </footer>
  </div>

  
  <script src="/lib/anime.min.js"></script>
  <script src="//cdn.jsdelivr.net/npm/jquery@3/dist/jquery.min.js"></script>
  <script src="//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.js"></script>
  <script src="//cdn.jsdelivr.net/npm/lozad@1/dist/lozad.min.js"></script>
  <script src="/lib/velocity/velocity.min.js"></script>
  <script src="/lib/velocity/velocity.ui.min.js"></script>

<script src="/js/utils.js"></script>

<script src="/js/motion.js"></script>


<script src="/js/schemes/pisces.js"></script>


<script src="/js/next-boot.js"></script>


  <script defer src="/lib/three/three.min.js"></script>


  



  <script>
  if (CONFIG.page.isPost) {
    wpac_init = window.wpac_init || [];
    wpac_init.push({
      widget: 'Rating',
      id    : 26171,
      el    : 'wpac-rating',
      color : 'fc6423'
    });
    (function() {
      if ('WIDGETPACK_LOADED' in window) return;
      WIDGETPACK_LOADED = true;
      var mc = document.createElement('script');
      mc.type = 'text/javascript';
      mc.async = true;
      mc.src = '//embed.widgetpack.com/widget.js';
      var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(mc, s.nextSibling);
    })();
  }
  </script>

  
<script src="/js/local-search.js"></script>













  

  


<script>
NexT.utils.loadComments(document.querySelector('#valine-comments'), () => {
  NexT.utils.getScript('//unpkg.com/valine/dist/Valine.min.js', () => {
    var GUEST = ['nick', 'mail'];
    var guest = 'nick,mail,link';
    guest = guest.split(',').filter(item => {
      return GUEST.includes(item);
    });
    new Valine({
      el         : '#valine-comments',
      verify     : false,
      notify     : false,
      appId      : 'puzQn5yHhkbtBj2VGFbqJ4FE-MdYXbMMI',
      appKey     : 'lmcgKM2surcxNxMRiqInHjkU',
      placeholder: "Just go go",
      avatar     : 'retro',
      meta       : guest,
      pageSize   : '10' || 10,
      visitor    : true,
      lang       : '' || 'zh-cn',
      path       : location.pathname,
      recordIP   : false,
      serverURLs : ''
    });
  }, window.Valine);
});
</script>
<div class="moon-menu">
  <div class="moon-menu-items">
    
    <div id="moon-menu-item-back2bottom" class="moon-menu-item" onclick="back2bottom()">
      <i class="fa fa-chevron-down"></i>    </div>
    
    <div id="moon-menu-item-back2top" class="moon-menu-item" onclick="back2top()">
      <i class="fa fa-chevron-up"></i>    </div>
    
  </div>
  <div class="moon-menu-button">
    <svg class="moon-menu-bg">
      <circle class="moon-menu-cricle" cx="50%" cy="50%" r="44%"/>
      <circle class="moon-menu-border" cx="50%" cy="50%" r="48%"/>
    </svg>
    <div class="moon-menu-content">
      <div class="moon-menu-icon"><i class="fas fa-ellipsis-v"></i></div>
      <div class="moon-menu-text"></div>
    </div>
  </div>
</div><script src="/js/injector.js"></script>
<!-- 数字雨 -->
<!-- <canvas id="canvas" width="1440" height="900" ></canvas> -->
<!-- <script type="text/javascript" src="/js/src/DigitalRain.js"></script> -->
<!-- 页面点击小红心 -->
<script type="text/javascript" src="/js/src/clicklove.js"></script>
<!--浏览器搞笑标题-->
<script type="text/javascript" src="/js/FunnyTitle.js"></script>
<!-- Live2D看板娘 -->
<!-- <script src="/live2d-widget/autoload.js"></script> -->
<!-- <script src="https://feirouafeirou.github.io/live2d-widget/autoload.js"></script> -->
<!-- 网页音乐播放器 -->
<!-- <link rel="stylesheet" href="/dist/APlayer.min.css">
<div id="aplayer"></div>
<script type="text/javascript" src="/dist/APlayer.min.js"></script>
<script type="text/javascript" src="/dist/music.js"></script> -->
</body>

</html>
